草庐IT

php - 匿名类构造

全部标签

c# - 使用简单名称声明匿名类型成员

当你尝试编译它时:varcar=new{"toyota",5000};您将收到编译器错误“无效的匿名类型成员声明符。必须使用成员赋值、简单名称或成员访问来声明匿名类型成员。”因为编译器无法推断各个表达式中的属性名称。这完全有道理。让我感到好奇的是,错误消息暗示了三种声明类型成员的有效方法。成员分配和成员访问是显而易见的://memberassignmentvarv=new{Amount=108,Message="Hello"};//memberaccessvarproductQuery=fromprodinproductsselectnew{prod.Color,prod.Price}

c# - C# 7 中的 C# 匿名类型是否多余

自从C#7引入值元组后,是否存在它们比元组更适合的有意义的场景?例如下面一行collection.Select((x,i)=>(x,i)).Where(y=>arr[y.i].f(y.x)).ToArray();生成如下行collection.Select((x,i)=>new{x,i}).Where(y=>arr[y.i].f(y.x)).ToArray();冗余。如果一个用例比另一个更好用(出于性能原因或优化原因),会是什么用例?显然,如果需要超过6个字段,则不能使用元组,但是否有更细微的差别? 最佳答案 匿名类型和C#7元组之

c# - 用户 (IPrincipal) 在使用 Web Api 2.1 和 Owin 的 ApiController 构造函数上不可用

我将WebApi2.1与Asp.NetIdentity2一起使用。我试图在我的ApiController的构造函数上获取经过身份验证的用户(我正在使用AutoFac注入(inject)我的依赖项),但是当构造函数是打电话。我正在尝试获取用户,以便为任何数据库写入操作生成审计信息。我正在做的一些事情可以帮助诊断:我正在使用仅app.UseOAuthBearerTokens作为Asp.NetIdentity2的身份验证。这意味着我删除了app.UseCookieAuthentication(newCookieAuthenticationOptions())当您使用Asp.NetIdenti

c# - 为什么局部函数生成的 IL 不同于匿名方法和 Lambda 表达式?

为什么C#7编译器将局部函数转换为其父函数所在的同一类中的方法。而对于匿名方法(和Lambda表达式),编译器会为每个父函数生成一个嵌套类,它将包含所有匿名方法作为实例方法?例如,C#代码(匿名方法):internalclassAnonymousMethod_Example{publicvoidMyFunc(string[]args){varx=5;Actionact=delegate(){Console.WriteLine(x);};act();}}将生成类似于以下内容的IL代码(匿名方法):.classprivateautoansibeforefieldinitAnonymousM

c# - 为什么 c# 编译器需要在 switch 构造中使用 break 语句?

我很难理解为什么编译器需要使用break语句。不可能错过它,因为现在允许掉落。我看到了C或C++中断的原因,但这里是否需要中断。为什么在案件结束后中断不是内置行为?它不只是没有语义的语法吗?抱歉,如果这是一个愚蠢的问题。编辑:仅当案例为空时才允许掉落。当那里有语句时,你不能省略break语句。所以,这是另一回事。 最佳答案 编译器并不“需要”break语句,它需要它们。这是一个设计决定。它使代码在语义上接近C和C++,同时消除了一直是C语言的一个有争议的“特性”的失败陷阱。 关于c#-为

c# - BlankPage 构造函数无法初始化组件

我开始learningXAML然后我将一些代码添加到我的BlankPage应用程序中。突然有一个正在初始化组件的构造函数:publicBlankPage(){this.InitializeComponent();}停止工作。我现在有这个错误:'BlankApplication.BlankPage'doesnotcontainadefinitionfor'InitializeComponent'andnoextensionmethod'InitializeComponent'acceptingafirstargumentoftype'BlankApplication.BlankPage'

C# 2.0 线程问题(匿名方法)

我有一个包含以下代码的简单应用程序:FileInfo[]files=(newDirectoryInfo(initialDirectory)).GetFiles();Listthreads=newList(files.Length);foreach(FileInfofinfiles){Threadt=newThread(delegate(){Console.WriteLine(f.FullName);});threads.Add(t);}foreach(Threadtinthreads)t.Start();假设在“I=initialDirectory”目录中我有3个文件。然后这个应用程序

c# - WPF 自定义控件构造、触发器和事件

我想构建一个新的自定义控件。我发现很少有教程能给我一些关于如何实现这一目标的线索。据我了解,创建新的自定义控件总是通过扩展当前控件来完成的,甚至可以扩展来自层次结构最基本级别的控件,例如,您甚至可以扩展:UI元素框架元素控制内容控制标题内容控件项目控制选择器范围基准如以下教程中所写:http://wpftutorial.net/HowToCreateACustomControl.html因此,我按照教程创建了一个自定义控件库类型的新项目,得到了我的通用.xaml和我的代码。到目前为止一切顺利。我可以区分3种类型或类别的事件。将由将使用我的控件的窗口(或容器)使用的事件:这些是我想向外部

c# - 为什么静态字段初始化发生在静态构造函数之前?

以下代码:staticvoidMain(string[]args){Console.WriteLine("0");stringh=Foo.X;Console.WriteLine("2");}publicstaticclassFoo{publicstaticstringX=((Func)delegate(stringg){Console.WriteLine(g);return(g);})("_aaa");staticFoo(){Console.WriteLine("ctor");}}将打印:0_aaactor2我知道beforefieldinit行为(有/没有静态构造函数等)。我不明白的

c# - 如果字段的顺序不同,为什么编译器会为匿名类型生成不同的类

我考虑过两种情况:vara=new{a=5};varb=new{a=6};Console.WriteLine(a.GetType()==b.GetType());//TrueIdeone:http://ideone.com/F8QwHY和:vara=new{a=5,b=7};varb=new{b=7,a=6};Console.WriteLine(a.GetType()==b.GetType());//FalseIdeone:http://ideone.com/hDTcxX问题是为什么字段顺序真的很重要?这是否有任何原因,或者仅仅是因为它是(这就是设计)。如果原因只是匿名类型不应该以这种